// 给你一个仅包含小写英文字母和 '?' 字符的字符串 s，请你将所有的 '?' 转换为若干小写字母，
// 使最终的字符串不包含任何 连续重复 的字符。

// 注意：你 不能 修改非 '?' 字符。

// 题目测试用例保证 除 '?' 字符 之外，不存在连续重复的字符。
// 在完成所有转换（可能无需转换）后返回最终的字符串。如果有多个解决方案，
// 请返回其中任何一个。可以证明，在给定的约束条件下，答案总是存在的。

// 示例 1：
// 输入：s = "?zs"
// 输出："azs"
// 解释：该示例共有 25 种解决方案，从 "azs" 到 "yzs" 都是符合题目要求的。
// 只有 "z" 是无效的修改，因为字符串 "zzs" 中有连续重复的两个 'z' 。

// 示例 2：
// 输入：s = "ubv?w"
// 输出："ubvaw"
// 解释：该示例共有 24 种解决方案，只有替换成 "v" 和 "w" 不符合题目要求。因为 "ubvvw" 和 "ubvww" 都包含连续重复的字符。

// 示例 3：
// 输入：s = "j?qg??b"
// 输出："jaqgacb"

// 示例 4：
// 输入：s = "??yw?ipkj?"
// 输出："acywaipkja"
//  
// 提示：
// 1 <= s.length <= 100
// s 仅包含小写英文字母和 '?' 字符
import java.util.Random;

class Solution {
    private Random rand = new Random();

    public String modifyString(String s) {
        int n = s.length();
        var res = new StringBuilder(n);
        if (s.charAt(0) == '?') {
            res.append(opt('?', 1 >= n ? '?' : s.charAt(1)));
        } else {
            res.append(s.charAt(0));
        }

        for (int i = 1; i < n - 1; i++) {
            if (s.charAt(i) == '?') {
                res.append(opt(res.charAt(i - 1), s.charAt(i + 1)));
            } else {
                res.append(s.charAt(i));
            }
        }

        if (n > 1) {
            if (s.charAt(n - 1) == '?') {
                res.append(opt(res.charAt(n - 2), '?'));
            } else {
                res.append(s.charAt(n - 1));
            }
        }
        return res.toString();
    }

    // 生成一个与 a,b 不同的小写字母
    private char opt(char a, char b) {
        char c = (char) (rand.nextInt(26) + 'a');
        if (c == a || c == b) {
            return opt(a, b);
        } else {
            return c;
        }
    }
}
